草庐IT

shell - 将 .csv 文件导入 sqlite3 db 表

全部标签

ruby - 使用 Ruby CSV 更改导出的 CSV 中的字段分隔符/定界符

是否可以将默认字段分隔符从逗号更改为其他字符,例如用于导出的'|'? 最佳答案 下面是一个使用选项卡的示例。到一个文件:CSV.open("myfile.csv","w",{:col_sep=>"\t"})do|csv|csv到一个字符串:csv_string=CSV.generate(:col_sep=>"\t")do|csv|csv这是关于CSV的当前文档:http://ruby-doc.org/stdlib/libdoc/csv/rdoc/index.html 关于ruby-使用R

Ruby 将 CSV 文件读取为 UTF-8 和/或将 ASCII-8Bit 编码转换为 UTF-8

我正在使用ruby1.9.2我正在尝试解析包含一些法语单词(例如spécifié)的CSV文件,并将内容放入MySQL数据库中。当我从CSV文件中读取行时,file_contents=CSV.read("csvfile.csv",col_sep:"$")返回的元素是ASCII-8BIT编码的字符串(spécifié变为sp\xE9cifi\xE9),然后像“spécifié”这样的字符串没有正确保存到我的MySQL数据库中。YehudaKatz表示ASCII-8BIT实际上是“二进制”数据,这意味着CSV不知道如何读取适当的编码。所以,如果我尝试让CSV强制编码如下:file_cont

ruby - 是否可以使用 Ruby 读取文件的修改日期?

是否可以使用Ruby读取文件的修改日期?我已经成功地打开了一个文本文件并捕获了文件的内容File.open("test.txt","r").eachdo|line|"但是读取文件的修改日期会非常有用。 最佳答案 使用mtime:File.mtime("testfile")=>2014-04-1316:00:23-0300 关于ruby-是否可以使用Ruby读取文件的修改日期?,我们在StackOverflow上找到一个类似的问题: https://stacko

Ruby 在特定目录下运行 shell 命令

我知道如何在Ruby中运行shell命令,例如:%x[#{cmd}]但是,我该如何指定一个目录来运行这个命令呢?有没有类似的脱shell方式,类似Python中的subprocess.Popen:subprocess.Popen(r'c:\mytool\tool.exe',cwd=r'd:\test\local')谢谢! 最佳答案 您可以使用Dir.chdir的block版本。在block内,您位于请求的目录中,在block之后,您仍在上一个目录中:Dir.chdir('mydir'){%x[#{cmd}]}

Ruby 无法加载此类文件 - active_support/core_ext/object/blank

我试图运行brewdoctor但系统弹出错误/System/Library/Frameworks/Ruby.framework/Versions/2.3/usr/lib/ruby/2.3.0/rubygems/core_ext/kernel_require.rb:55:in`require':cannotloadsuchfile--active_support/core_ext/object/blank(LoadError)在线搜索和另一篇帖子建议只“geminstallactivesupport”但后来我遇到了以下错误:ERROR:Errorinstallingactivesuppo

ruby - 在不将整个文件读入内存的情况下计算文件中的行数?

我正在处理庞大的数据文件(每个文件有数百万行)。在我开始处理之前,我想计算文件中的行数,这样我就可以指出处理的进度。由于文件的大小,将整个文件读入内存是不切实际的,只是计算有多少行。有人对如何执行此操作有好的建议吗? 最佳答案 一次一行读取文件:count=File.foreach(filename).inject(0){|c,line|c+1}或Perl-ishFile.foreach(filename){}count=$.或count=0File.open(filename){|f|count=f.read.count("\n"

ruby - 如何在 Ruby 中重命名文件?

这是我的.rb文件:puts"Renamingfiles..."folder_path="/home/papuccino1/Desktop/Test"Dir.glob(folder_path+"/*").sort.eachdo|f|filename=File.basename(f,File.extname(f))File.rename(f,filename.capitalize+File.extname(f))endputs"Renamingcomplete."文件从它们的初始目录移动到.rb文件所在的位置。我想当场重命名文件,而不移动它们。有什么建议吗?

ruby-on-rails - 使用 send_file 从 Amazon S3 下载文件?

我的应用程序中有一个下载链接,用户应该可以从该链接下载存储在s3上的文件。这些文件将可通过类似以下形式的url公开访问https://s3.amazonaws.com/:bucket_name/:path/:to/:file.png下载链接在我的Controller中点击了一个Action:classAttachmentsController但是当我尝试下载文件时出现以下错误:ActionController::MissingFileinAttachmentsController#showCannotreadfilehttps://s3.amazonaws.com/:bucket_na

ruby-on-rails - 如何让carrierwave在销毁记录时删除文件?

我正在使用carrierwavegem上传文件。我建立了一个系统,供用户将图像标记为不当图像,并供管理员删除图像。据我所知,对图像调用destroy只会从表中删除路径名。有没有办法让carrierwave实际删除文件本身?或者当我破坏图像路径时,rails应该自动删除文件吗? 最佳答案 就像@mu_is_too_short说的,你可以使用File#delete。这是一个代码片段,您可以在Rails应用程序中稍加调整后将其用作帮助程序。defremove_file(file)File.delete(file)end或者如果您只是将文件

ruby - 在 ruby​​ 的同一目录中是否有更短的方法来要求文件?

是否有更短的方法来要求位于同一目录(与正在执行的脚本)中的文件?requireFile.expand_path(File.dirname(__FILE__)+'/some_other_script')我读到require"my_script"和require"./my_script"实际上会加载脚本两次(ruby不会识别它实际上是同一个脚本),这就是为什么推荐File.expand_path的原因:如果每次需要脚本时都使用它,那么它只会被加载一次。我觉得很奇怪,像Ruby这样简洁的语言似乎没有更短的解决方案。例如,python简单地有这个:import.some_other_modul